Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

inv-loggers

Package Overview
Dependencies
Maintainers
1
Versions
32
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

inv-loggers

loggers and partial loggers

  • 3.3.15
  • latest
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
4
decreased by-20%
Maintainers
1
Weekly downloads
 
Created
Source

a little server-side library to log things with colors, with a special care for promise chains

Summary

  • Installation
  • Functions
  • License

Installation

in a terminal at your project root:

npm install inv-loggers --save

then in your javascript project:

var log = require('inv-loggers')

or as I prefer, extend your _ object

var _ = require('lodash') // or var _ = require('underscore')
var loggers = require('inv-loggers')
_.extend _, loggers

this is the syntax we will use in the following examples

Functions

Basics

log

the basic logger from which all others are just variations

var obj = {a: 1}
_.log(obj, 'that zuper obj')

which in logs, generate something like:

****** that zuper obj ******
{ a: 1 }
-----

with some colors that can't be made visible in this markdown file (in the caseof _.log, cyan)

And that's pretty much all: a label with fat delimiters and some colors to make your debugging/logs scanning easy

NB: returns the object for convenience

success

The same but in green

info

The same but in blue

warn

The same but in yellow

NB: returns undefined to avoid returning an error object

error

The same but in red, used to log error objects.

It will try to log err.stack instead of just the err object to get a stack trace in logs when available

NB: returns undefined to avoid returning an error object

errorRethrow

The same as error but throws the error object instead of just returning undefined (especially useful used as a partial in a promise chain, see hereafter)

Partials

in promise chains, it can be useful to log an object passed at the middle of the chain, but using just those loggers would be sub-optimal, verbose:

getSomeData()
.then(function (result) { return _.log(result, 'some data') })
.then(doSomethingWithIt)
.catch(function (error) { _.error(error, 'some data error')})

so we use partials instead, to which we pass a label and which returns a function with a label pre-set. So we can rewrite this example like so:

getSomeData()
.then(_.Log('some data'))
.then(doSomethingWithIt)
.catch(_.Error('some data error'))

Note here that if we want to be able to log an error generated in this chain but still be able to handle it elsewhere, we need to make sure the error is rethrown, which can be done by replacing the last line with

.catch(_.ErrorRethrow('some data error'))

The partial functions have the same name as the basic functions but simply capitalized: Log, Info, Success, Warn, Error, ErrorRethrow

Capitalizing high-order functions as such is a convention used in my projects as I use very few constructors, but you might thing it is an heretic choice. In this case, don't use this library.

License

MIT

Keywords

FAQs

Package last updated on 05 Dec 2020

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc